package com.sistema.produto;

import java.util.List;

import org.hibernate.Criteria;
import org.hibernate.Query;
import org.hibernate.Session;

public class ProdutoDAOHibernate implements ProdutoDAO {

	private Session session;

	public Session getSession() {
		return session;
	}

	public void setSession(Session session) {
		this.session = session;
	}

	@Override
	public void save(Produto produto) {
		this.session.save(produto);
	}

	@Override
	public Produto getProdutoWithDescricao(String descricao) {
		String sql = "from Produto p where p.descricao like :descricao";
		Query query = this.session.createQuery(sql);
		query.setString("descricao", "%" + descricao + "%");
		return (Produto) query.uniqueResult();
	}

	@Override
	public void delete(Produto produto) {
		this.session.delete(produto);
	}

	@SuppressWarnings("unchecked")
	@Override
	public List<Produto> getAllProduto() {
		Criteria criteria = this.session.createCriteria(Produto.class);
		return criteria.list();
	}

	@Override
	public void update(Produto produto) {
		this.session.update(produto);
	}
}
